<template>
  <a-card :bordered="false" class="card-area">
    <!-- 查询区域 -->
    <div class="table-page-search-wrapper">
      <!-- 搜索区域 -->
      <a-form layout="inline">
        <a-row :gutter="24">
          <a-col :md="6" :sm="8">
            <a-form-item label="名称" :labelCol="{span: 5}" :wrapperCol="{span: 18, offset: 1}">
              <a-input placeholder="请输入名称查询" v-model="queryParam.name"></a-input>
            </a-form-item>
          </a-col>
          <a-col :md="10" :sm="12">
            <a-form-item label="创建时间" :labelCol="{span: 5}" :wrapperCol="{span: 18, offset: 1}">
              <j-date
                v-model="queryParam.createTime_begin"
                :showTime="true"
                date-format="YYYY-MM-DD HH:mm:ss"
                style="width:45%"
                placeholder="请选择开始时间"
              ></j-date>
              <span style="width: 10px;">~</span>
              <j-date
                v-model="queryParam.createTime_end"
                :showTime="true"
                date-format="YYYY-MM-DD HH:mm:ss"
                style="width:45%"
                placeholder="请选择结束时间"
              ></j-date>
            </a-form-item>
          </a-col>
          <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
            <a-col :md="6" :sm="24">
              <a-button type="primary" @click="searchQuery">查询</a-button>
              <a-button style="margin-left: 8px" @click="searchReset">重置</a-button>
            </a-col>
          </span>
        </a-row>
      </a-form>
    </div>

    <!-- 操作按钮区域 -->
    <div class="table-operator" style="margin-top: 5px">
      <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>

      <a-dropdown v-if="selectedRowKeys.length > 0">
        <a-menu slot="overlay">
          <a-menu-item key="1" @click="batchDel">
            <a-icon type="delete"/>
            删除
          </a-menu-item>
        </a-menu>
        <a-button style="margin-left: 8px">
          批量操作
          <a-icon type="down"/>
        </a-button>
      </a-dropdown>
    </div>

    <!-- table区域-begin -->
    <div>
      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
        <i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择&nbsp;
        <a style="font-weight: 600">{{ selectedRowKeys.length }}</a>项&nbsp;&nbsp;
        <a style="margin-left: 24px" @click="onClearSelected">清空</a>
      </div>

      <a-table
        ref="table"
        size="middle"
        bordered
        rowKey="id"
        :columns="columns"
        :dataSource="dataSource"
        :pagination="ipagination"
        :loading="loading"
        :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
        @change="handleTableChange"
      >
        <span slot="action" slot-scope="text, record">
          <a @click="copyTemplate(record)">
            <img class="src" src="../../img/fuzhi.png" title="复制模板"></a>
          <a-divider type="vertical"/>

         <!-- <a @click="handleEdit(record)">编辑</a>-->
        <a  @click="handleEdit(record)" v-if="record.modelstatus==''" >
          <img class="src" src="../../img/bianji.png" title="编辑"></a>
        <a  @click="modelShow(record)" v-if="record.modelstatus=='1'" >
          <img class="src" src="../../img/chakan.png" title="查看"></a>
                <a-popconfirm title="确定部署吗?" @confirm="() => handleDeploy(record.id)">
                  <a v-if="!record.deploymentId"><img class="src" src="../../img/fabu.png" title="部署"></a>
                </a-popconfirm>
                <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
                  <a v-if="record.refModal=='0'"><img class="src" src="../../img/shanchu.png" title="删除"></a>
                </a-popconfirm>
        </span>
      </a-table>
    </div>
    <!-- table区域-end -->

    <!-- 表单区域 -->
    <bpmn-modal ref="modalForm" @ok="modalFormOk"></bpmn-modal>
    <show-template ref="ShowTemplate"/>
    <copy-template ref="copyTemplate" @ok="modalFormOk"></copy-template>
  </a-card>
</template>

<script>
  import BpmnModal from './modules/ActivitiModelModal'
  import {JantdListMixin} from '@/mixins/JantdListMixin'
  import JDate from '@/components/jantd/JDate'
  import {deployModel,copyTemplate} from '@/api/activiti'
  import ShowTemplate from './modules/ShowTemplate'
  import CopyTemplate from "./modules/copyTemplate";

  export default {
    name: 'ModelList',
    mixins: [JantdListMixin],
    components: {
      CopyTemplate,
      BpmnModal,
      ShowTemplate,
      JDate
    },
    data() {
      return {
        description: '流程管理页面',
        // 查询条件
        queryParam: {name: ''},
        // 表头
        columns: [
          {
            title: '#',
            dataIndex: '',
            key: 'rowIndex',
            width: 40,
            align: 'center',
            customRender: function (t, r, index) {
              return parseInt(index) + 1
            }
          },
          {
            title: '名称',
            align: 'center',
            dataIndex: 'name'
          },
/*          {
            title: '单位',
            align: 'center',
            dataIndex: 'company'
          },*/
          {
            title: '描述',
            align: 'center',
            dataIndex: 'description'
          },
          {
            title: '类别',
            align: 'center',
            dataIndex: 'category'
          },
          {
            title: '版本',
            align: 'center',
            dataIndex: 'version'
          },
          {
            title: '创建时间',
            dataIndex: 'createTime',
            align: 'center',
            sorter: true
          },
          {
            title: '更新时间',
            dataIndex: 'lastUpdateTime',
            align: 'center',
            sorter: true
          },
          {
            title: '操作',
            dataIndex: 'action',
            align: 'center',
            scopedSlots: {customRender: 'action'}
          }
        ],
        url: {
          list: '/act/model/list',
          delete: '/act/model/delete'
        }
      }
    },
    computed: {},
    methods: {
      handleDeploy: function (modelId) {
        const that = this
        deployModel(modelId).then(res => {
          if (res.success) {
            that.$message.success(res.message)
            that.searchQuery()
          } else {
            that.$message.warning(res.message)
          }
        })
      },
      onChangeDate(date, dateString) {
        console.log(date, dateString)
      },
      //查看
      modelShow(record){
        let that = this
        that.$refs.ShowTemplate.show(record);
      },
      copyTemplate(record){
        let that = this
        that.$refs.copyTemplate.edit(record);


        // copyTemplate(record).then(function (res) {
        //     console.log(res)
        //     that.$message.info("模板复制成功")
        //     that.searchQuery()
        // }).catch(function (err) {
        //     console.log(err)
        //     that.$message.info(err)
        // })
      }
    }
  }
</script>
<style scoped>
  @import '~@assets/less/common.less';
</style>